<template>
  <div>
    <el-form ref="formRef" label-width="100px" :model="form" :rules="rules">
      <el-form-item label="付款账户">
        {{ infoData.payAccount }}
      </el-form-item>
      <el-form-item label="收款账户">
        {{ infoData.gatheringAccount }}
      </el-form-item>
      <el-form-item label="收款人姓名">
        {{ infoData.gatheringName }}
      </el-form-item>
      <el-form-item label="转账金额">
        <strong>￥{{ infoData.price }}元</strong>
      </el-form-item>
      <el-form-item label="支付密码" prop="password">
        <el-input v-model="form.password" clearable type="password" />
      </el-form-item>
    </el-form>
    <div class="pay-button-group">
      <el-button :loading="loading" type="primary" @click="handleSubmit">提交</el-button>
      <el-button @click="handlePrev">上一步</el-button>
    </div>
  </div>
</template>

<script lang="ts" setup>
defineOptions({
  name: 'Step2',
})
defineProps({
  infoData: {
    type: Object,
    default: () => {
      return {}
    },
  },
})
const emit = defineEmits(['change-step'])

const formRef = ref<any>(null)
const form = reactive<any>({
  password: '123456',
})
const rules = reactive<any>({
  password: [{ required: true, message: '请输入支付密码', trigger: 'blur' }],
})
const loading = ref<boolean>(false)

const handleSubmit = () => {
  formRef.value.validate((valid: any) => {
    if (valid) {
      loading.value = true
      setTimeout(() => {
        emit('change-step', 2)
        loading.value = false
      }, 2000)
    } else {
      loading.value = false
    }
  })
}
const handlePrev = () => {
  emit('change-step', 0)
}
</script>

<style lang="scss" scoped>
.pay-button-group {
  display: block;
  margin: 20px auto;
  text-align: center;
}
</style>
